রিকার্সন এবং ইটারেশন প্রোগ্রামিংয়ে বারবার পুনরাবৃত্তি করে কাজ সম্পন্ন করার দুটি পদ্ধতি। এই দুই পদ্ধতি কার্যক্ষমতা এবং প্রয়োগের ক্ষেত্রে পার্থক্য রয়েছে। চলুন রিকার্সন এবং ইটারেশনের ধারণা, প্রয়োগ এবং পার্থক্য সম্পর্কে আলোচনা করা যাক।
রিকার্সন একটি প্রোগ্রামিং পদ্ধতি যেখানে একটি ফাংশন নিজেই নিজেকে বারবার কল করে কাজ সম্পন্ন করে। রিকার্সনে সাধারণত একটি বেস কেস (যেখানে রিকার্সন থামে) এবং একটি রিকার্সিভ কেস (যেখানে ফাংশন নিজেকে পুনরায় কল করে) থাকে। রিকার্সন সাধারণত জটিল সমস্যাগুলিকে সরল এবং পুনরাবৃত্তভাবে সমাধান করার জন্য ব্যবহৃত হয়।
ফ্যাক্টরিয়াল গণনার জন্য একটি রিকার্সিভ ফাংশন লেখা যেতে পারে যেভাবে:
(defn factorial [n]
(if (<= n 1)
1
(* n (factorial (dec n)))))
এখানে, factorial
ফাংশনটি নিজেই নিজেকে কল করছে যতক্ষণ পর্যন্ত n
এর মান ১ বা তার চেয়ে কম না হয়। এই ফাংশনটি n
এর মানকে প্রতি রিকার্সিভ কলে কমিয়ে দেয় এবং অবশেষে ফ্যাক্টরিয়াল রিটার্ন করে।
ইটারেশন একটি পদ্ধতি যেখানে একটি নির্দিষ্ট শর্ত পর্যন্ত একটি লুপ বারবার চালানো হয়। ইটারেশন সাধারণত for, while, বা loop কন্সট্রাক্ট ব্যবহার করে করা হয়। ইটারেশন লুপের মাধ্যমে কাজ সম্পন্ন করে এবং সাধারণত কম মেমোরি ব্যবহার করে, কারণ এটি স্ট্যাক ফ্রেমের উপর নির্ভর করে না।
ফ্যাক্টরিয়াল গণনার জন্য একটি ইটারেটিভ পদ্ধতি লেখা যেতে পারে এভাবে:
(defn factorial [n]
(loop [i n, acc 1]
(if (<= i 1)
acc
(recur (dec i) (* acc i)))))
এখানে loop
এবং recur
ব্যবহার করে একটি লুপ তৈরি করা হয়েছে। i
দ্বারা প্রতিবার n
এর মান কমানো হয় এবং acc
এর সাথে গুণ করা হয়। যখন i
এর মান ১ বা তার চেয়ে কম হয়ে যায়, তখন acc
রিটার্ন হয়।
বৈশিষ্ট্য | রিকার্সন | ইটারেশন |
---|---|---|
কাজের পদ্ধতি | ফাংশন নিজেই নিজেকে পুনরায় কল করে | একটি নির্দিষ্ট শর্ত পর্যন্ত লুপ চলতে থাকে |
স্ট্যাক ব্যবহার | প্রতিটি রিকার্সিভ কল একটি নতুন স্ট্যাক ফ্রেম তৈরি করে | লুপ একই স্ট্যাক ফ্রেমে কাজ সম্পন্ন করে |
কোড সরলতা | ছোট এবং সহজ কোডের জন্য উপযুক্ত | লজিক সহজ হলে সরাসরি ব্যবহার করা যায় |
কার্যক্ষমতা | বড় ইনপুটে স্ট্যাক ওভারফ্লো হতে পারে | বড় ইনপুটে মেমোরি এবং সময় সাশ্রয়ী |
ব্যবহার ক্ষেত্র | জটিল ও বিভাজ্য সমস্যাগুলিতে কার্যকর | সাধারণ পুনরাবৃত্তিমূলক কাজের জন্য উপযুক্ত |
রিকার্সন এবং ইটারেশন উভয়ই পুনরাবৃত্তিমূলক কাজের জন্য ব্যবহৃত হয়, তবে প্রয়োগের ক্ষেত্রে এদের মধ্যে পার্থক্য রয়েছে। রিকার্সন জটিল সমস্যার সমাধানে উপযোগী, যখন ইটারেশন বড় ডেটাসেটের জন্য মেমোরি দক্ষতা বৃদ্ধি করে।
common.read_more